<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <!-- 通过修改 `style` 属性，将所有外部链接变为橙色。 

对于这个例子而言，如果一个链接是外部的需要满足下面两个条件：

- 其 `href` 中包含 `://`
- 但不是以 `http://internal.com` 开头。 -->
    <a name="list">the list</a>
    <ul>
        <li><a href="http://google.com">http://google.com</a></li>
        <li><a href="/tutorial">/tutorial.html</a></li>
        <li><a href="local/path">local/path</a></li>
        <li><a href="ftp://ftp.com/my.zip">ftp://ftp.com/my.zip</a></li>
        <li><a href="http://nodejs.org">http://nodejs.org</a></li>
        <li><a href="http://internal.com/test">http://internal.com/test</a></li>
    </ul>

    <script>
        // // 为单个链接设置样式
        //    let link = document.querySelector('a');
        //   link.style.color = 'orange';
        let link = document.querySelectorAll('a');
        // console.log('123');
        for (var i = 0; i < link.length; i++) {
            // link[i].style.color = 'red';
            // console.log(typeof link[i].getAttribute('href'));
            // arr.push(link[i].getAttribute('href'));
            let str = link[i].getAttribute("href");
            // 因为有的标签缺少 href属性导致index of 的时候 是null ，产生报错。
            // 因为开发的页面里有很多的a标签，但是有的a标签是做按钮使用的，所以会造成a标签没有href属性： 比如
            // <a role="button" class="submit-btn">确认</a>
            // 在进行index of 的时候，先把null的情况排除，即无href的标签。添加 != null
            if (str != null && str.indexOf('://') != -1 && str.indexOf('http://internal.com') == -1) {
                link[i].style.color = 'orange';
            }
        }
    </script>
</body>

</html>